<?php

function index() {
    global $contenido;

    $dbc = conectarBD();
    $resultado = pg_query($dbc, "SELECT * FROM empresa;");
    if (!$resultado) {

        $contenido["error"] = "No se ha podido contactar a la base de datos.";
    } else {
        $empresas = pg_fetch_all($resultado);
        if (!$empresas)
            $contenido["info"] = "No hay empresas en la base de datos.";
        else
            $contenido["empresas"] = $empresas;
    }
    pg_close($dbc);
}

function view() {
    global $contenido;

    $rut = @$_GET["rut"];
    if (!$rut) {
        $contenido["error"] = "Debe especificar el rut de la empresa.";
    } else {
        $dbc = conectarBD();
        pg_prepare($dbc, "delete_query", "SELECT * FROM empresa WHERE rut = $1;");
        $resultado = pg_execute($dbc, "delete_query", array($rut));
        $resultadoArray = pg_fetch_all($resultado);
        pg_close($dbc);
        if (!$resultado || !$resultadoArray) {
            $contenido["error"] = "No se ha encontrado una empresa con el rut indicado.";
        } else {
            $contenido["empresa"] = $resultadoArray[0];
        }
    }
}

function create() {
    Response::$view = "form";
}

function edit() {
    global $contenido;
    view();
    Response::$view = "form";
}

function persist() {
    global $contenido;
    $_GET["rut"] = $_POST["rut"];
    view();

    $dbc = conectarBD();
    if (!array_key_exists("empresa", $contenido)) {
        $consulta = "INSERT INTO empresa VALUES(".$_POST["rut"].",".$_POST["empresa_nombre"].");";
        pg_prepare($dbc, "persist_query", "INSERT INTO empresa VALUES($1,$2)");
    } else {
        $consulta = "UPDATE empresa SET empresa_nombre=".$_POST["empresa_nombre"]." WHERE rut=".$_POST["rut"].";";
        pg_prepare($dbc, "persist_query", "UPDATE empresa SET empresa_nombre=$2 WHERE rut=$1");
    }
    
    $resultado = pg_execute($dbc, "persist_query", $_POST);
    pg_close($dbc);
    if (!$resultado || $resultado == 0) {
        $contenido["error"] = "No se ha podido guardar la empresa.";
    } else {
        $contenido = array();
        $contenido["exito"] = "Los datos de la empresa se han guardado exitosamente.";
        $log = guardarEnLog($consulta);
    }

    index();
    Response::$view = "index";
}

function delete() {
    global $contenido;

    $rut = @$_POST["rut"];
    if (!$rut) {
        $contenido["error"] = "Debe especificar el rut de la empresa.";
    } else {
        $dbc = conectarBD();
        $consulta = "DELETE FROM empresa WHERE rut = ".$_POST["rut"].";";
        pg_prepare($dbc, "delete_query", "DELETE FROM empresa WHERE rut = $1");
        $resultado = pg_execute($dbc, "delete_query", array($rut));
        pg_close($dbc);
        if (!$resultado || pg_affected_rows($resultado) == 0) {
            $contenido["error"] = "No se ha encontrado una empresa con el rut indicado.";
        } else {
            $contenido["alerta"] = "Se ha eliminado correctamente la empresa especificada.";
            $log = guardarEnLog($consulta);
        }
    }

    index();
    Response::$view = "index";
}

?>
